

# درس معماری کامپیوتر

استاد: دکتر حمید سربازی آزاد نیمسال بهار ۱۴۰۱

## فاز اول پروژه

اعضای گروه: پویا یوسفی (۹۸۱۷۱۲۲۳) محمدرضا احمدی تشنیزی (۹۸۱۷۰۶۴۶) سجاد پاکسیما (۹۸۱۰۶۲۸۶) مهدیه ابراهیمپور (۹۸۱۷۰۶۲۴)

#### مقدمه

در این فاز از پروژه، قصد داریم پردازندهای را با استفاده از زبان Verilog طراحی کنیم که بر مبنای معماری MIPS که یک یردازنده RISC است، طراحی کنیم.

پردازشگر MIPS از نوع single-cycle است و وظایف fetch کردن، decode کردن، دسترسی به حافظه و بازنویسی و... را در یک clock انجام می دهد و پاسخ را حاضر می کند. در این پردازنده ابتدا مقدار PC به عنوان آدرسی برای شماره گذاری در یک عنوان خروجی آماده می کند.

### مسير داده (Datapath)

بر اساس مجموعه دستورالعملهای ارائه شده، مسیر داده و واحد کنترل به شکل زیر طراحی و پیادهسازی شدهاست.



#### ماژولها:

#### ماژول Control Unit:

در این ماژول پس از دریافت opdcode و مقدار func و مقدار opcode و مقدار opcode و مقدار مقدار و alu\_opcode و opcode o

#### ماژول Alu Control:

پس از مشخص شدن سیگنال کنترلی  $alu_op$  در این ماژول عملیات  $alu_op$  را مشخص می کنیم. علاوه بر alu\_op به ورودی func برای مشخص کردن دستورهای فرمت  $alu_op$  نیاز است. مانند ماژول func برای مشخص کردن دستورات از  $alu_op$  کمک می گیریم. سیگنال ورودی  $alu_op$  از دستورات از  $alu_op$  کمک می گیریم. سیگنال ورودی  $alu_op$  از دستورا

### ماژول ALU:

این ماژول، واحد alu است که عملیاتهای مورد نیاز را بر روی ورودیهای خود انجام میدهد. این ماژول به کمک کمک sh.amount ،func و sh.amount و sh.amount و sh.amount و sh.amount و sh.amount این کار انجام می پذیرد. ورودیهای sh.amount و sh.amount از دستور گرفته میشوند و ورودی alu\_select از alu\_select

### ماژول Mips Core:

بخش اصلی در این ماژول است که ورودی ها و خروجی ها به کمک سیمها به قسمتهای مورد نیاز وصل میشوند و ارتباط را برقرار میکنند. همچنین به کمک مالتیپلکسر، میتوانیم بسته به سیگنال های کنترلی، اتصالات سیمها را به صورت مناسب انجام دهیم. مقدار بعدی PC و مشخص شدن آدرس دستور نیز در این ماژول انجام میشود. مقدار فعلی PC بعد از عبور از ادرهای مختلف و مالتیپلکسرهای گوناگون، آماده أماده میشود. مقدار اولیه PC را برابر با صفر میگذاریم چون پردازنده دستورات را از اول برنامه (خط اول) کردن میشود. مقدار اولیه کمک سیگنالهای کنترلی branch, jr, jal, jump پردازنده آماده دستورات پرش میشود میخواند. به کمک سیگنالهای کنترلی دستور branch به سیگنال که خروجی واحد alu میباشد نیاز (قسمت بالایی branch). البته برای دستور branch به سیگنال کنترلی که از Control Unit خارج میشود قابل اجرا هستند.